package com.jhh.mybatis;

import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.OutputFile;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.engine.VelocityTemplateEngine;

import java.util.Collections;

public class CodeGenerator {

    public static void main(String[] args) {
        // 配置数据源，替换成你的数据库信息
        FastAutoGenerator.create("jdbc:mysql://localhost:3306/jhh_bishe?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai",
                        "root",
                        "089812") // 数据库连接和密码
                .globalConfig(builder -> {
                    builder.author("jhh") // 设置作者
                            .outputDir(System.getProperty("user.dir") + "/src/main/java") // 指定输出目录
                            .commentDate("yyyy-MM-dd") // 注释中的日期格式
                            .dateType(DateType.ONLY_DATE) // 日期类型
                            .disableOpenDir(); // 生成后禁止打开目录
                })
                .packageConfig(builder -> {
                    builder.parent("com.jhh") // 设置父包名
//                            .moduleName("bishe") // 设置模块名，这里假设为 bishe
                            .pathInfo(Collections.singletonMap(OutputFile.xml,
                                    System.getProperty("user.dir") + "/src/main/resources/master/mapper/xml")); // 设置Mapper XML生成路径
                })
                .strategyConfig(builder -> {
                    builder.addInclude("user_table") // 设置需要生成的表名，修改成你自己的表名
                            .addTablePrefix("t_", "sys_") // 设置过滤表前缀
                            .entityBuilder().enableLombok() // 开启 Lombok 注解
                            .mapperBuilder().enableBaseResultMap().enableBaseColumnList() // 生成基础的 ResultMap 和 ColumnList
                            .controllerBuilder().enableRestStyle(); // 开启 RestController 风格
                })
                .templateEngine(new VelocityTemplateEngine()) // 使用 Velocity 模板引擎
                .execute();
    }
}
